//导入数据库操作模块
const db = require('../db/index')
//导入 bcryptjs 这个包
const bcrypt = require('bcryptjs')


//注册新用户的处理函数
exports.regUser = (req, res) => {
    //获取客户端提交到服务器的用户信息
    const userinfo = req.body
    //对表单中的数据，进行合法性的校验
    // if(!userinfo.username || userinfo.password) {
    //     return res.send({status: 1, message: '用户名或密码不合法！'})
    // }

    //定义 SQL 语句，查询用户名是否被占用
    const sqlStr = 'select * from ev_users where username=?'
    db.query(sqlStr, userinfo.username, (err, results) => {
        //执行 SQL 语句失败
        if(err) {
            // return res.send({status: 1, message: err.message})
            return res.cc(err)
        }
        //判断用户名是否被占用
        if(results.length > 0){
            // return res.send({status: 1, message: '用户名被占用，请更换其他用户名!'})
            return res.cc('用户名被占用，请更换其他用户名!')
        }
        //TODO：用户名可以使用
        //调用 bcrypt.hashSync() 对密码进行加密
    
        userinfo.password =  bcrypt.hashSync(userinfo.password, 10)
        //定义插入新用户的 SQL 语句
        const sql = 'insert into ev_users set ?'
        //调用 db.query() 执行 SQL 语句
        db.query(sql, {username: userinfo.username, password: userinfo.password}, (err, results) => {
            //判断 SQL 语句是否执行成功
            // if(err) return res.send({ status: 1, message: err.message})
            if(err) return res.cc(err)
            //判断影响行数是否为1
            // if(results.affectedRows !== 1) return res.send({status: 1, message: '注册用户失败，请稍后再试！'})
            if(results.affectedRows !== 1) return res.cc('注册用户失败，请稍后再试！')
            //注册用户成功
            // res.send({status: 0, message: '注册成功！'})
            res.cc('注册成功！', 0) 
        })
    
    })
}

//登录的处理函数
exports.login = (req, res) => {
    //接受表单的数据
    const userinfo = req.body
    //定义 SQL 语句
    const sql = `select * from ev_users where username=?`
    //执行 SQL 语句，根据用户名查询用户的信息
    db.query(sql, userinfo.username, (err, results) => {
        //执行 SQL 语句失败
        if(err) return res.cc(err)
        //执行 SQL 成功, 但是获取到的数据条数不等于 1
        if(results.length !== 1) return res.cc('登录失败！')


        //TODO：判断密码是否正确
        // res.send('login OK')
        const compareResult = bcrypt.compareSync(userinfo.password, results[0].password)
        if(!compareResult) return res.cc('登录失败！')
        res.send('ok')
    })
  
}